<!DOCTYPE html>
<html xmlns:wb="http://open.weibo.com/wb">
<head>
  <meta charset="utf-8">
  <script src="https://cdn.jsdelivr.net/gh/Sanarous/files@1.13/js/linkcard.js"></script>
  <script>
(function(){
    var bp = document.createElement('script');
    var curProtocol = window.location.protocol.split(':')[0];
    if (curProtocol === 'https') {
        bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';
    }
    else {
        bp.src = 'http://push.zhanzhang.baidu.com/push.js';
    }
    var s = document.getElementsByTagName("script")[0];
    s.parentNode.insertBefore(bp, s);
})();
</script>
<script>
var _hmt = _hmt || [];
(function() {
  var hm = document.createElement("script");
  hm.src = "https://hm.baidu.com/hm.js?fc9a8559a133f4d8ce784d69d6337bb0";
  var s = document.getElementsByTagName("script")[0]; 
  s.parentNode.insertBefore(hm, s);
})();
</script>

  
  <title>springcloud微服务三：Eureka服务治理之注册服务提供者及服务的发现和消费 | 涂宗勋的博客</title>
  <meta name="baidu-site-verification" content="o8pWlgAEZ7" />
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  <meta name="description" content="说明当服务注册中心成功建立以后，就需要有服务的注册和消费，否则这个服务注册中心就没有了存在的意义，而实际上，一个简单的服务注册也是非常简单的，仅仅需要实现四部曲就好。 服务注册步骤一首先，还是建立一个基本的spring boot的项目，创建的时候选择web，然后在pom.xml文件中加入Eureka的依赖，和服务注册中心的maven配置一样，这里就不再罗列代码。 步骤二第二步，就是修改applic">
<meta property="og:type" content="article">
<meta property="og:title" content="springcloud微服务三：Eureka服务治理之注册服务提供者及服务的发现和消费">
<meta property="og:url" content="https://tuzongxun.gitee.io/2017/05/24/springcloud3/index.html">
<meta property="og:site_name" content="涂宗勋的博客">
<meta property="og:description" content="说明当服务注册中心成功建立以后，就需要有服务的注册和消费，否则这个服务注册中心就没有了存在的意义，而实际上，一个简单的服务注册也是非常简单的，仅仅需要实现四部曲就好。 服务注册步骤一首先，还是建立一个基本的spring boot的项目，创建的时候选择web，然后在pom.xml文件中加入Eureka的依赖，和服务注册中心的maven配置一样，这里就不再罗列代码。 步骤二第二步，就是修改applic">
<meta property="og:locale" content="zh_CN">
<meta property="og:image" content="https://tuzongxun.gitee.io/images/springcloud/s31.png">
<meta property="og:image" content="https://tuzongxun.gitee.io/images/springcloud/s32.png">
<meta property="og:image" content="https://tuzongxun.gitee.io/images/springcloud/s33.png">
<meta property="article:published_time" content="2017-05-24T07:09:42.000Z">
<meta property="article:modified_time" content="2019-10-17T03:29:11.728Z">
<meta property="article:author" content="涂宗勋">
<meta property="article:tag" content="java">
<meta property="article:tag" content="springcloud">
<meta name="twitter:card" content="summary">
<meta name="twitter:image" content="https://tuzongxun.gitee.io/images/springcloud/s31.png">
  
  
    <link rel="icon" href="/images/touxiang.png">
  
  
    
  
  
<link rel="stylesheet" href="/tzxblog/css/style.css">

  

<meta name="generator" content="Hexo 4.2.1"></head>

<body>
  <div id="container">
    <div id="wrap">
      <header id="header">
  <script src="https://tjs.sjs.sinajs.cn/open/api/js/wb.js" type="text/javascript" charset="utf-8"></script>
  <script src="https://cdn.jsdelivr.net/gh/Sanarous/files@1.13/js/linkcard.js"></script>
  <div id="banner"></div>
  <div id="header-outer" class="outer">
    
    <div id="header-inner" class="inner">
      <nav id="sub-nav">
        
        <a id="nav-search-btn" class="nav-icon" title="搜索"></a>
      </nav>
      <div id="search-form-wrap">
        <form action="//google.com/search" method="get" accept-charset="UTF-8" class="search-form"><input type="search" name="q" class="search-form-input" placeholder="Search"><button type="submit" class="search-form-submit">&#xF002;</button><input type="hidden" name="sitesearch" value="https://tuzongxun.gitee.io"></form>
      </div>
      <nav id="main-nav">
        <a id="main-nav-toggle" class="nav-icon"></a>
        
          <a class="main-nav-link" href="/tzxblog/">首页</a>
        
          <a class="main-nav-link" href="/tzxblog/shuoshuo/">说说</a>
        
          <a class="main-nav-link" href="/tzxblog/archives/">归档</a>
        
          <a class="main-nav-link" href="/tzxblog/collections/">导航</a>
        
          <a class="main-nav-link" href="/tzxblog/download/">资源</a>
        
          <a class="main-nav-link" href="/tzxblog/about/">简历</a>
        
      </nav>
      
    </div>
    <div id="header-title" class="inner">
      <h1 id="logo-wrap">
        <a href="/tzxblog/" id="logo">涂宗勋的博客</a>
      </h1>
      
        <h2 id="subtitle-wrap">
          <a href="/tzxblog/" id="subtitle">java程序员，现居武汉，CSDN博客https://blog.csdn.net/tuzongxun</a>&nbsp;&nbsp;&nbsp;&nbsp;
		  <!--<span id="busuanzi_container_site_pv">【本站累计访问量:<span id="busuanzi_value_site_pv"></span>】</span>-->
        </h2>
		
      
    </div>
  </div>
</header>
      <div class="outer">
        <section id="main"><article id="post-springcloud3" class="article article-type-post" itemscope itemprop="blogPost">
  <div class="article-meta">
    <a href="/tzxblog/2017/05/24/springcloud3/" class="article-date">
  <time datetime="2017-05-24T07:09:42.000Z" itemprop="datePublished">2017-05-24</time>
</a>
    
  <div class="article-category">
    <a class="article-category-link" href="/tzxblog/categories/springcloud/">springcloud</a>
  </div>

</span>
  </div>
  <div class="article-inner">
    
    
      <header class="article-header">
        
  
    <h1 class="article-title" itemprop="name">
      springcloud微服务三：Eureka服务治理之注册服务提供者及服务的发现和消费
    </h1>
  

      </header>
    
    <div class="article-entry" itemprop="articleBody">
      
        <!-- Table of Contents -->
        
        <h1 id="说明"><a href="#说明" class="headerlink" title="说明"></a>说明</h1><p>当服务注册中心成功建立以后，就需要有服务的注册和消费，否则这个服务注册中心就没有了存在的意义，而实际上，一个简单的服务注册也是非常简单的，仅仅需要实现四部曲就好。</p>
<h1 id="服务注册"><a href="#服务注册" class="headerlink" title="服务注册"></a>服务注册</h1><h2 id="步骤一"><a href="#步骤一" class="headerlink" title="步骤一"></a>步骤一</h2><p>首先，还是建立一个基本的spring boot的项目，创建的时候选择web，然后在pom.xml文件中加入Eureka的依赖，和服务注册中心的maven配置一样，这里就不再罗列代码。</p>
<h2 id="步骤二"><a href="#步骤二" class="headerlink" title="步骤二"></a>步骤二</h2><p>第二步，就是修改application.properties文件，指定端口和服务名称以及注册中心的地址：</p>
<pre>
server.port=1001
spring.application.name=hello-service
eureka.client.serviceUrl.defaultZone=http://server1:1000/eureka/,http://server2:2000/eureka/
</pre>

<p>因为上一步中实现了注册中心的集群模式，因此这里可以指定两个，如果有更多的服务注册中心，还可以指定更多，中间以逗号分隔。</p>
<h2 id="步骤三"><a href="#步骤三" class="headerlink" title="步骤三"></a>步骤三</h2><p>第三步，使用注解开启自动装配，使服务能够向注册中心注册、向注册中心服务租约（实际上就是定时器持续发送心跳告诉服务注册中心自己还活着）、取消租约、查询服务列表等，这个注解是@EnableDiscoveryClient，添加以后的代码如下：</p>
<pre>
@EnableDiscoveryClient
@SpringBootApplication
public class EurekaService1Application {
    public static void main(String[] args) {
        SpringApplication.run(EurekaService1Application.class, args);
    }
}
</pre>

<h2 id="步骤四"><a href="#步骤四" class="headerlink" title="步骤四"></a>步骤四</h2><p>第四步，我们说要进行服务注册，当上边一切准备工作做好以后，自然需要有服务才能注册，而这个服务就是一个看起来很普通的controller类，如图：</p>
<pre>
@RestController
public class HelloController {  
    @Autowired
    private DiscoveryClient client;
    @RequestMapping(value="/hello",method=RequestMethod.GET)
    public String sayHello(){
        ServiceInstance instance=client.getLocalServiceInstance();
        return "hello "+instance.getHost()+","+instance.getPort()+","+instance.getServiceId();
    }
}
</pre>

<p>这里的DiscoveryClient可以获取注册到服务注册中心的服务的相关信息，并不是必须注入的，这里完全可以写成如下所示的代码：</p>
<pre>
@RestController
public class HelloController {  
    @RequestMapping(value="/hello",method=RequestMethod.GET)
    public String sayHello(){
        return "hello";
    }
}
</pre>

<p>当然了，因为只是了解服务注册的过程，所以这里仅仅这么简单，实际的业务逻辑自然不会是这样。</p>
<p>那么通过上边四步，一个能够注册到服务注册中心提供服务的服务就完成了，启动这个服务就会被注册到服务注册中心，我们可以通过服务注册中心的页面来查看：<br><img src="/images/springcloud/s31.png" alt="cloud1"></p>
<p>成功的创建了一个服务并注册到注册中心，同样的，为了高可用，我们可以再建一个具有同样功能的服务，而这个过程就更加的简单，只需要更改一下端口号，也就是server.port，然后重新启动就可以，启动后会看到上边的页面如下（当然了，这里也是为了测试方便，实际情况也应该是在两台机器上运行的两套代码才对）：<br><img src="/images/springcloud/s32.png" alt="cloud2"></p>
<p>这里我们会看到已经有了两个同应用名的服务，端口分别是1001和2001。<br>而在上述页面中还需要注意的是那一段醒目的红色提示，它的意思就是说开启了自我保护机制，也就是说当服务失效后，有可能注册中心还会保留一段时间该服务的信息，这样就可能导致服务消费方获取服务列表的时候依然能够获取到这个服务，但是实际上向该服务发送请求的时候又无法成功请求，那么学习的过程中可以使用以下配置关闭自我保护机制，然后如果再访问注册中心的页面便不会再出现这个提示，也不会出现那种服务失效后还保留在注册中心的情况。</p>
<pre>
#设置是否开启自我保护机制，默认是true
eureka.server.enable-self-preservation=false
</pre>

<h1 id="服务发现"><a href="#服务发现" class="headerlink" title="服务发现"></a>服务发现</h1><p>服务注册好以后，下边就是服务的发现和消费，通常有ribbon和feign两种方式，而feign实际上也是以ribbon为基础的，这两种后边都还需要具体详细的学习，所以这里只简单的演示一下消费的过程，不做太详细的解释。ribbon可以实现负载均衡，这里使用最简单的模板实现。<br>首先还是建立一个基础spring boot项目，然后pom.xml中加入eureka和ribbon的依赖以及eureka的版本信息：</p>
<pre>
&lt;dependency>
    &lt;groupId>org.springframework.cloud&lt;/groupId>
    &lt;artifactId>spring-cloud-starter-eureka&lt;/artifactId>
&lt;/dependency>        
&lt;dependency>
    &lt;groupId>org.springframework.cloud&lt;/groupId>
    &lt;artifactId>spring-cloud-starter-ribbon&lt;/artifactId>
&lt;/dependency>
&lt;dependencyManagement>
        &lt;dependencies>
            &lt;dependency>
               &lt;groupId>org.springframework.cloud&lt;/groupId>
               &lt;artifactId>spring-cloud-dependencies&lt;/artifactId>
               &lt;version>Brixton.RELEASE&lt;/version>
               &lt;type>pom&lt;/type>
               &lt;scope>import&lt;/scope>
            &lt;/dependency>
        &lt;/dependencies>
&lt;/dependencyManagement>
</pre>

<p>然后application.properties文件内容如下：</p>
<pre>
server.port=3001
spring.application.name=rabbit-client
eureka.client.serviceUrl.defaultZone=http://server1:1000/eureka/,http://server2:2000/eureka/
</pre>

<p>再然后就是创建项目时生成的类中加入@EnableDiscoveryClient参数开启自动装配，以及注入服务消费模板并开启负载均衡：</p>
<pre>
@Bean
@LoadBalanced
RestTemplate restTemplate(){
    return new RestTemplate();
}
</pre>

<p>之后的这个步骤实际不是必要的，只是为了能够更直观的在页面中看到结果，所以加入一个controller类，输出服务的一些基本信息：</p>
<pre>
@RestController
public class ConsumerController {    
    @Autowired
    RestTemplate restTemplate;
    @RequestMapping(value="/hello",method=RequestMethod.GET)
    public String hello(){
        return restTemplate.getForEntity("http://HELLO-SERVICE/hello", String.class).getBody();
    }
}
</pre>

<p>那么当我们启动这个消费端以后，页面访问localhost:3001/hello就可以看到如下页面：<br><img src="/images/springcloud/s33.png" alt="cloud3"></p>

      
    </div>
    <footer class="article-footer">
      <a data-url="https://tuzongxun.gitee.io/2017/05/24/springcloud3/" data-id="ckxn7cxiu0057kcvhcot0f09j" class="article-share-link">分享</a>
      
      
      
  <ul class="article-tag-list" itemprop="keywords"><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tzxblog/tags/java/" rel="tag">java</a></li><li class="article-tag-list-item"><a class="article-tag-list-link" href="/tzxblog/tags/springcloud/" rel="tag">springcloud</a></li></ul>

    </footer>
  </div>
  
    
  <div class="comments" id="comments">
    
     
       
       
      
      
	 
  </div>
 
    
 
<script src="/tzxblog/jquery/jquery.min.js"></script>

  <div id="random_posts">
    <h2>推荐文章</h2>
    <div class="random_posts_ul">
      <script>
          var random_count =5
          var site = {BASE_URI:'/tzxblog/'};
          function load_random_posts(obj) {
              var arr=site.posts;
              if (!obj) return;
              // var count = $(obj).attr('data-count') || 6;
              for (var i, tmp, n = arr.length; n; i = Math.floor(Math.random() * n), tmp = arr[--n], arr[n] = arr[i], arr[i] = tmp);
              arr = arr.slice(0, random_count);
              var html = '<ul>';
            
              for(var j=0;j<arr.length;j++){
                var item=arr[j];
                html += '<li><strong>' + 
                item.date + ':&nbsp;&nbsp;<a href="' + (site.BASE_URI+item.uri) + '">' + 
                (item.title || item.uri) + '</a></strong>';
                if(item.excerpt){
                  html +='<div class="post-excerpt">'+item.excerpt+'</div>';
                }
                html +='</li>';
                
              }
              $(obj).html(html + '</ul>');
          }
          $('.random_posts_ul').each(function () {
              var c = this;
              if (!site.posts || !site.posts.length){
                  $.getJSON(site.BASE_URI + 'js/posts.js',function(json){site.posts = json;load_random_posts(c)});
              } 
               else{
                load_random_posts(c);
              }
          });
      </script>
    </div>
  </div>

	
<nav id="article-nav">
  
    <a href="/tzxblog/2017/05/26/springcloud4/" id="article-nav-newer" class="article-nav-link-wrap">
      <strong class="article-nav-caption">上一篇</strong>
      <div class="article-nav-title">
        
          springcloud微服务四：服务容错保护Hystrix断路器
        
      </div>
    </a>
  
  
    <a href="/tzxblog/2017/05/23/springcloud2/" id="article-nav-older" class="article-nav-link-wrap">
      <strong class="article-nav-caption">下一篇</strong>
      <div class="article-nav-title">springcloud微服务二：Eureka服务治理之服务注册中心</div>
    </a>
  
</nav>

  
</article>

</section>
           
    <aside id="sidebar">
  
    <!--微信公众号二维码-->


  
    

  
    
  
    
    <div class="widget-wrap">
    
      <div class="widget" id="toc-widget-fixed">
      
        <strong class="toc-title">文章目录</strong>
        <div class="toc-widget-list">
              <ol class="toc"><li class="toc-item toc-level-1"><a class="toc-link" href="#说明"><span class="toc-number">1.</span> <span class="toc-text">说明</span></a></li><li class="toc-item toc-level-1"><a class="toc-link" href="#服务注册"><span class="toc-number">2.</span> <span class="toc-text">服务注册</span></a><ol class="toc-child"><li class="toc-item toc-level-2"><a class="toc-link" href="#步骤一"><span class="toc-number">2.1.</span> <span class="toc-text">步骤一</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#步骤二"><span class="toc-number">2.2.</span> <span class="toc-text">步骤二</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#步骤三"><span class="toc-number">2.3.</span> <span class="toc-text">步骤三</span></a></li><li class="toc-item toc-level-2"><a class="toc-link" href="#步骤四"><span class="toc-number">2.4.</span> <span class="toc-text">步骤四</span></a></li></ol></li><li class="toc-item toc-level-1"><a class="toc-link" href="#服务发现"><span class="toc-number">3.</span> <span class="toc-text">服务发现</span></a></li></ol>
          </div>
      </div>
    </div>

  
    

  
    
  
    
  
    

  
</aside>

      </div>
      <footer id="footer">
  <script async src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script>
  
  <div class="outer">
    <div id="footer-left">
      &copy; 2016 - 2021 涂宗勋&nbsp; <a href="https://beian.miit.gov.cn/#/Integrated/recordQuery" target="_blank" rel="noopener">鄂ICP备20000142号</a> |&nbsp;&nbsp;
      主题 <a href="https://github.com/giscafer/hexo-theme-cafe/" target="_blank">Cafe</a>&nbsp;|&nbsp;&nbsp;
	  <span id="busuanzi_container_site_uv">本站有效访客数<span id="busuanzi_value_site_uv"></span>人</span>
	  <span id="busuanzi_container_site_pv" >| 总访问量 <span id="busuanzi_value_site_pv"></span> 次 </span>
	  <div style="width:300px;margin:0 auto; padding:20px 0;"><a target="_blank" href="http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=42010302002171"style="display:inline-block;text-decoration:none;height:20px;line-height:20px;"><img src="http://www.tzxcode.cn/wp-content/uploads/2020/01/备案图标.png" style="float:left;"/><p style="float:left;height:20px;line-height:20px;margin: 0px 0px 0px 5px; color:#939393;">鄂公网安备 42010302002171号</p></a>
		 	</div>
    </div>
     <div id="footer-right">
      联系方式&nbsp;|&nbsp;1160569243@qq.com
    </div>
	
  </div>
</footer>
 
<script src="/tzxblog/jquery/jquery.min.js"></script>

 <script>
$(document).ready(function() {

    var int = setInterval(fixCount, 50);  // 50ms周期检测函数
    var countOffset = 20000;  // 初始化首次数据

    function fixCount() {            
       if (document.getElementById("busuanzi_container_site_pv").style.display != "none")
        {
            $("#busuanzi_value_site_pv").html(parseInt($("#busuanzi_value_site_pv").html()) + countOffset); 
            clearInterval(int);
        }                  
        if ($("#busuanzi_container_site_pv").css("display") != "none")
        {
            $("#busuanzi_value_site_uv").html(parseInt($("#busuanzi_value_site_uv").html()) + countOffset); // 加上初始数据 
            clearInterval(int); // 停止检测
        }  
    }
       	
});
</script> 
    </div>
    <nav id="mobile-nav">
  
    <a href="/tzxblog/" class="mobile-nav-link">首页</a>
  
    <a href="/tzxblog/shuoshuo/" class="mobile-nav-link">说说</a>
  
    <a href="/tzxblog/archives/" class="mobile-nav-link">归档</a>
  
    <a href="/tzxblog/collections/" class="mobile-nav-link">导航</a>
  
    <a href="/tzxblog/download/" class="mobile-nav-link">资源</a>
  
    <a href="/tzxblog/about/" class="mobile-nav-link">简历</a>
  
</nav>
    <img class="back-to-top-btn" src="/images/fly-to-top.png"/>
<script>
// Elevator script included on the page, already.
window.onload = function() {
  var elevator = new Elevator({
    selector:'.back-to-top-btn',
    element: document.querySelector('.back-to-top-btn'),
    duration: 1000 // milliseconds
  });
}
</script>
      

  

  







<!-- author:forvoid begin -->
<!-- author:forvoid begin -->

<!-- author:forvoid end -->

<!-- author:forvoid end -->



 
<script src="/tzxblog/js/is.js"></script>



  
<link rel="stylesheet" href="/tzxblog/fancybox/jquery.fancybox.css">

  
<script src="/tzxblog/fancybox/jquery.fancybox.pack.js"></script>




<script src="/tzxblog/js/script.js"></script>


<script src="/tzxblog/js/elevator.js"></script>

  </div>
</body>
</html>